Scroll to navigation

SYMLINKAT(2) Руководство программиста Linux SYMLINKAT(2)

ИМЯ

symlinkat - создаёт символьную ссылку, определяемую относительно файлового дескриптора каталога

ОБЗОР

#include <fcntl.h> /* определения констант AT_* */
#include <unistd.h>

int symlinkat(const char *oldpath, int newdirfd, const char *newpath);


Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):

symlinkat():

Начиная с glibc 2.10:
_XOPEN_SOURCE >= 700 || _POSIX_C_SOURCE >= 200809L
До glibc 2.10:
_ATFILE_SOURCE

ОПИСАНИЕ

Системный вызов symlinkat() работает также как symlink(2), за исключением описанных, описанных в данной справочной странице.

Если в newpath задан относительный путь, то он считается относительно каталога, на который ссылается файловый дескриптор newdirfd (а не относительно текущего рабочего каталога вызывающего процесса, как это делается в symlink(2)).

Если в newpath задан относительный путь и newdirfd равно специальному значению AT_FDCWD, то newpath рассматривается относительно текущего рабочего каталога вызывающего процесса (как symdlink(2)).

Если в newpath задан абсолютный путь, то newdirfd игнорируется.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении symlinkat() возвращается 0; при ошибке возвращается -1, а в errno содержится код ошибки.

ОШИБКИ

В symlinkat() могут возникнуть те же ошибки, что и в symdlink(2). Также, в symlinkat() могут возникнуть следующие ошибки:

newdirfd не является правильным файловым дескриптором.
Значение newpath содержит относительный путь и newdirfd содержит файловый дескриптор, указывающий на файл, а не на каталог.

ВЕРСИИ

Системный вызов symlinkat() был добавлен в ядро Linux версии 2.6.16; поддержка в glibc доступна с версии 2.4.

СООТВЕТСТВИЕ СТАНДАРТАМ

POSIX.1-2008.

ЗАМЕЧАНИЯ

Смотрите в openat(2) объяснение необходимости symlinkat().

СМОТРИТЕ ТАКЖЕ

openat(2), symlink(2), path_resolution(7), symlink(7)

2012-05-04 Linux